主题
下载文件 - HttpDownloadFile
函数简介
下载文件,支持断点续传与进度回调。
接口名称
HttpDownloadFileDLL调用
c
int32_t HttpDownloadFile(int64_t instance, const char* url, const char* save_path, DownloadCallback callback, int64_t user_data);参数说明
| 参数名 | 类型 | 说明 |
|---|---|---|
| instance | 长整数型 | OLAPlug对象的指针,由 CreateCOLAPlugInterFace 接口生成。 |
| url | 字符串 | 完整URL |
| save_path | 字符串 | 本地保存路径 |
| callback | DownloadCallback | 回调函数,用于接收下载进度 |
| user_data | 长整数型 | 传给callback的用户数据 |
回调函数类型定义
c
void DownloadCallback(int64_t current, int64_t total, int64_t speed, int64_t user_data);| 参数名 | 类型 | 说明 |
|---|---|---|
| current | 长整数型 | 已下载字节数 |
| total | 长整数型 | 总字节数(0表示未知) |
| speed | 长整数型 | 当前下载速度(字节/秒) |
| user_data | 长整数型 | 由调用方传入的用户数据 |
错误码
| 错误码 | 说明 |
|---|---|
| 0 | 下载成功 |
| -1 | 无效的URL |
| -2 | 无法创建文件 |
| -3 | 无法写入文件 |
| -4 | 连接失败 |
| -5 | 超时 |
| -6 | DNS解析失败 |
| -7 | SSL/TLS错误 |
| -404 | 404文件不存在 |
| -403 | 403禁止访问 |
| -500 | 500服务器错误 |
| -502 | 502网关错误 |
| -503 | 503服务不可用 |
| -999 | 未知错误 |
示例
SDK 调用
cpp
#include "OLAPlugServer.h"
OLAPlugServer ola;
int ret = ola.HttpDownloadFile("https://example.com/file.zip", "D:\\downloads\\file.zip", nullptr, 0);csharp
using OLAPlug;
var ola = new OLAPlugServer();
int ret = ola.HttpDownloadFile("https://example.com/file.zip", "D:\\downloads\\file.zip", nullptr, 0);python
from OLAPlugServer import OLAPlugServer
ola = OLAPlugServer()
ret = ola.HttpDownloadFile("https://example.com/file.zip", "D:\\downloads\\file.zip", nullptr, 0)java
import com.olaplug.OLAPlugServer;
OLAPlugServer ola = new OLAPlugServer();
int ret = ola.HttpDownloadFile("https://example.com/file.zip", "D:\\downloads\\file.zip", nullptr, 0);cpp
var ola = com("OlaPlug.OlaSoft")
var ret = ola.HttpDownloadFile("https://example.com/file.zip", "D:\\downloads\\file.zip", nullptr, 0)vbscript
Set ola = CreateObject("OlaPlug.OlaSoft")
ret = ola.HttpDownloadFile("https://example.com/file.zip", "D:\\downloads\\file.zip", nullptr, 0)text
.局部变量 ola, OLAPlug
ola.创建 ()
ret = ola.HttpDownloadFile(“https://example.com/file.zip“, “D:\\downloads\\file.zip“, nullptr, 0)aardio
import OLAPlugServer;
var ola = OLAPlugServer();
var ret = ola.HttpDownloadFile("https://example.com/file.zip", "D:\\downloads\\file.zip", nullptr, 0);text
变量 ola <类型 = OLAPlugServer>
ola = 新建 OLAPlugServer
整数 ret = ola.HttpDownloadFile("https://example.com/file.zip", "D:\\downloads\\file.zip", nullptr, 0)cpp
#include "OLAPlugServer.h"
OLAPlugServer ola;
int ret = ola.HttpDownloadFile("https://example.com/file.zip", "D:\\downloads\\file.zip", nullptr, 0);原生 DLL 调用
cpp
long instance = CreateCOLAPlugInterFace();
HttpDownloadFile(instance, "https://example.com/file.zip", "D:\\downloads\\file.zip", nullptr, 0);csharp
long instance = CreateCOLAPlugInterFace();
HttpDownloadFile(instance, "https://example.com/file.zip", "D:\\downloads\\file.zip", nullptr, 0);python
from ctypes import CDLL, c_int, c_int64, create_string_buffer
ola = CDLL("OLAPlug_x64.dll")
ola.CreateCOLAPlugInterFace.restype = c_int64
instance = ola.CreateCOLAPlugInterFace()
HttpDownloadFile(instance, "https://example.com/file.zip", "D:\\downloads\\file.zip", nullptr, 0)返回值
整数型,错误码,0表示成功,负数表示失败(参见错误码表)。
注意事项
- 支持断点续传,如果文件已部分下载,会自动从断点处继续
- 回调函数在下载过程中会被多次调用
- 如果不需要进度回调,可以传NULL
- 支持HTTP和HTTPS协议
